<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
                      "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
    <meta http-equiv="content-type" content="text/html; charset=UTF-8"/>
    <title>Juntando tudo - Zend Framework Manual</title>

    <link href="../css/shCore.css" rel="stylesheet" type="text/css" />
    <link href="../css/shThemeDefault.css" rel="stylesheet" type="text/css" />
    <link href="../css/styles.css" media="all" rel="stylesheet" type="text/css" />
</head>
<body>
<h1>Zend Framework</h1>
<h2>Programmer's Reference Guide</h2>
<ul>
    <li><a href="../en/learning.paginator.together.html">Inglês (English)</a></li>
    <li><a href="../pt-br/learning.paginator.together.html">Português Brasileiro (Brazilian Portuguese)</a></li>
</ul>
<table width="100%">
    <tr valign="top">
        <td width="85%">
            <table width="100%">
                <tr>
                    <td width="25%" style="text-align: left;">
                    <a href="learning.paginator.control.html">Pagination Control and ScrollingStyles</a>
                    </td>

                    <td width="50%" style="text-align: center;">
                        <div class="up"><span class="up"><a href="learning.paginator.html">Iniciando com o Zend_Paginator</a></span><br />
                        <span class="home"><a href="manual.html">Guia de Refer&ecirc;ncia do Programador</a></span></div>
                    </td>

                    <td width="25%" style="text-align: right;">
                        <div class="next" style="text-align: right; float: right;"><a href="reference.html">Refer&ecirc;ncia do Zend Framework</a></div>
                    </td>
                </tr>
            </table>
<hr />
<div id="learning.paginator.together" class="section"><div class="info"><h1 class="title">Juntando tudo</h1></div>
    

    <p class="para">
        Você viu como criar um objeto Paginator, como mostrar os itens da página atual,
        e como mostrar os elementos para navegar pelas páginas. Nesta seção você
        irá ver como o Paginator se encaixa com o restante da sua aplicação MVC.
    </p>

    <p class="para">
        Nos exemplos a seguir nos vamos ignorar as boas práticas de implementação de um serviço em
        camadas para manter o exemplo simples e fácil de entender. Estando familiarizado
        com o uso de camadas, será fácil ver como o Paginator pode se encaixar dentro de uma abordagem
        com melhores práticas.
    </p>

    <p class="para">
        Vamos começar com o controlador. A aplicação de exemplo é simples, e nós vamos colocar
        tudo no controlador Index (IndexController) e no método Index (IndexAction). Novamente,
        isto é apenas para propósito de demonstração. Uma aplicação real não deve usar controllers
        dessa maneira.
    </p>

    <pre class="programlisting brush: php">
class IndexController extends Zend_Controller_Action
{
    public function indexAction()
    {
        // Setup pagination control view script. See the pagation control tutorial page
        // for more information about this view script.
        Zend_View_Helper_PaginationControl::setDefaultViewPartial(&#039;controls.phtml&#039;);

        // Fetch an already instantiated database connection from the registry
        $db = Zend_Registry::get(&#039;db&#039;);

        // Create a select object which fetches blog posts, sorted decending by date of creation
        $select = $db-&gt;select()-&gt;from(&#039;posts&#039;)-&gt;sort(&#039;date_created DESC&#039;);

        // Create a Paginator for the blog posts query
        $paginator = Zend_Paginator::factory($select);

        // Read the current page number from the request. Default to 1 if no explicit page number is provided.
        $paginator-&gt;setCurrentPageNumber($this-&gt;_getParam(&#039;page&#039;, 1));

        // Assign the Paginator object to the view
        $this-&gt;view-&gt;paginator = $paginator;
    }
}
</pre>


    <p class="para">
        O código a seguir é a index.phtml para o método Index (IndexAction) do controlador Index
        (IndexController). A view pode ser simples. Vamos assumir o uso padrão de exibição
        ScrollingStyle para a paginação.
    </p>

    <pre class="programlisting brush: php">
&lt;ul&gt;
&lt;?php
// Render each the title of each post for the current page in a list-item
foreach ($this-&gt;paginator as $item) {
    echo &#039;&lt;li&gt;&#039; . $item-&gt;title . &#039;&lt;/li&gt;&#039;;
}
?&gt;
&lt;/ul&gt;
&lt;?php echo $this-&gt;paginator; ?&gt;
</pre>


    <p class="para">
        Agora navegue para a index do seu projeto e vejo o Paginator em ação. O que vimos nesse
        tutorial é apenas a ponta do iceberg. O manual de referência e a documentação da
        <acronym class="acronym">API</acronym> irá te mostrar mais do que você pode fazer com
        <span class="classname">Zend_Paginator</span>.
    </p>
</div>
        <hr />

            <table width="100%">
                <tr>
                    <td width="25%" style="text-align: left;">
                    <a href="learning.paginator.control.html">Pagination Control and ScrollingStyles</a>
                    </td>

                    <td width="50%" style="text-align: center;">
                        <div class="up"><span class="up"><a href="learning.paginator.html">Iniciando com o Zend_Paginator</a></span><br />
                        <span class="home"><a href="manual.html">Guia de Refer&ecirc;ncia do Programador</a></span></div>
                    </td>

                    <td width="25%" style="text-align: right;">
                        <div class="next" style="text-align: right; float: right;"><a href="reference.html">Refer&ecirc;ncia do Zend Framework</a></div>
                    </td>
                </tr>
            </table>
</td>
        <td style="font-size: smaller;" width="15%"> <style type="text/css">
#leftbar {
	float: left;
	width: 186px;
	padding: 5px;
	font-size: smaller;
}
ul.toc {
	margin: 0px 5px 5px 5px;
	padding: 0px;
}
ul.toc li {
	font-size: 85%;
	margin: 1px 0 1px 1px;
	padding: 1px 0 1px 11px;
	list-style-type: none;
	background-repeat: no-repeat;
	background-position: center left;
}
ul.toc li.header {
	font-size: 115%;
	padding: 5px 0px 5px 11px;
	border-bottom: 1px solid #cccccc;
	margin-bottom: 5px;
}
ul.toc li.active {
	font-weight: bold;
}
ul.toc li a {
	text-decoration: none;
}
ul.toc li a:hover {
	text-decoration: underline;
}
</style>
 <ul class="toc">
  <li class="header home"><a href="manual.html">Guia de Refer&ecirc;ncia do Programador</a></li>
  <li class="header up"><a href="manual.html">Guia de Refer&ecirc;ncia do Programador</a></li>
  <li class="header up"><a href="learning.html">Conhecendo o Zend Framework</a></li>
  <li class="header up"><a href="learning.paginator.html">Iniciando com o Zend_Paginator</a></li>
  <li><a href="learning.paginator.intro.html">Introdu&ccedil;&atilde;o</a></li>
  <li><a href="learning.paginator.simple.html">Exemplos simples</a></li>
  <li><a href="learning.paginator.control.html">Pagination Control and ScrollingStyles</a></li>
  <li class="active"><a href="learning.paginator.together.html">Juntando tudo</a></li>
 </ul>
 </td>
    </tr>
</table>

<script type="text/javascript" src="../js/shCore.js"></script>
<script type="text/javascript" src="../js/shAutoloader.js"></script>
<script type="text/javascript" src="../js/main.js"></script>

</body>
</html>